<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="root">
        <h2>学校:{{name}}</h2>
        <h2>地址:{{adress}}</h2>
    </div>

    <!-- 引入Vue -->
    <script src="../js/vue.js"></script>
    <script>
        Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示。
        
        let data = {
            name:'华北水利水电大学',
            adress:'龙子湖校区'
        }

        // 创建一个监视实例对象，用于监视data中属性的变化
        const obs = new Observer(data)
        console.log(obs)

        function Observer(obj){
            // 汇总对象中的所有属性形成一个数组
            const keys = Object.keys(obj)

            // 遍历
            keys.forEach((k) => {
                Object.defineProperty(this,k,{
                    get(){
                        return obj[k]
                    },
                    set(val){
                        console.log("val被修改了")
                        obj[k] = val;
                    }
                })
            });
        }
    </script>
</body>
</html>